package com.it.utils;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

//生成SqlSessionFactory  --> 制造SqlSession对象
//因为工厂模式，所以这里用的是单例模式
@SuppressWarnings("all")
public class MybatisUtils {

	private static SqlSessionFactory sqlSessionFactory;

	static {
		try {
			//获取sqlSessionFactory对象
			String resource = "mybatis-config.xml";
			InputStream inputStream = Resources.getResourceAsStream(resource);
			sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	//既然有了 SqlSessionFactory，顾名思义，我们可以从中获得 SqlSession 的实例
	// SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。你可以通过 SqlSession 实例来直接执行已映射的 SQL 语句
	public static SqlSession getSqlSession() {
		return sqlSessionFactory.openSession();
	}
}
